AMENDMENTS TO THE CLAIMS 



This listing of claims will replace all prior versions, and listings, of claims 
in the application: 

Listing of Claims: 



1 1 . (Currently amended) A method for performing a lock-free update 

2 to one or more fields in an existing node in a linked list, comprising: 

3 receiving a reference to the existing node in the linked list, wherein the 

4 existing node contains the one or more fields to be updated; 

5 obtaining a new node to be added to the linked list, wherein other 

6 processes do not possess references to the new node and therefore cannot initially 

7 access the new node; 

8 copying a snapshot of the existing node to the new node, which includes 

9 copying a next pointer of the existing node to the new node, so that the new node 

10 points to a node immediately following the existing node; 

1 1 updating one or more fields in the new node that correspond to the one or 

12 more fields in the existing node; 

13 performing a single atomic operation that modifies the next pointer of the 

14 existing node to point to the new node and also marks the next pointer to indicate 

15 that the existing node is deleted, whereby the new node becomes part of the linked 

16 list and the existing node is deleted in a single atomic operation; and 

17 splicing the existing node out of the linked list by atomically modifying 

1 8 the next pointer of a node immediately preceding the existing node in the linked 

1 9 list to point to the new node, instead of pointing to the existing nodevi 
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20 wherein copying the snapshot of the existing node to the new node further 

21 involves examining the next pointer of the existing node to determine if the 

22 existing node has been deleted. 

1 2. (Cancelled) 

1 3. (Previously presented) The method of claim 1 , wherein if a process 

2 that deleted the existing node does not perform the splicing operation, another 

3 process, which subsequently detects that the existing node has been deleted, 

4 performs the splicing operation. 

1 4. (Previously presented) The method of claim 1, wherein copying a 

2 snapshot of the existing node to the new node involves: 

3 copying the contents of the existing node to the new node; 

4 examining the next pointer of the existing node to determine if the existing 

5 node has been deleted; and 

6 if so, taking a remedial action; 

7 otherwise, not taking the remedial action. 

1 5. (Previously presented) The method of claim 4, wherein taking the 

2 remedial action involves: 

3 following the next pointer of the existing node in an attempt to find an 

4 updated version of the existing node; 

5 if an updated version of the existing node is found, copying a snapshot of 

6 the updated version of the existing node to the new node; and 

7 if an updated version of the existing node is not found, indicating that the 

8 remedial action fails. 
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1 6. (Original) The method of claim 1, further comprising deleting a 

2 target node from the linked list by: 

3 receiving a reference to the target node to be deleted from the linked list; 

4 atomically marking a next pointer in the target node to indicate that the 

5 target node is deleted; and 

6 atomically modifying the next pointer of a node immediately preceding the 

7 target node in the linked list to point to a node immediately following the target 

8 node in the linked list, instead of pointing to the target node, thereby splicing the 

9 target node out of the linked list. 



1 7. (Original) The method of claim 6, wherein after the target node is 

2 spliced out of the linked list, the method further comprises modifying the next 

3 pointer of the target node so that the next pointer remains marked but points to a 

4 node immediately preceding the target node instead of the node immediately 

5 following node the target node in the linked list. 

1 8. (Original) The method of claim 1, further comprising inserting an 

2 additional node into the linked list by: 

3 identifying a node immediately preceding the additional node in the linked 

4 list; 

5 identifying a node immediately following the additional node in the linked 

6 list; and 

7 splicing the additional node into the linked list by, 

8 setting the next pointer for the additional node to point to 

9 the immediately following node, and 

1 0 atomically updating the next pointer of the immediately 

1 1 preceding node to point to the additional node. 
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1 9. (Previously presented) The method of claim 1, further comprising 

2 reading a snapshot of multiple fields from a target node in the linked list by: 

3 reading the multiple fields from the target node; 

4 examining the next pointer of the target node to determine if the target 

5 node has been deleted; and 

6 if so, taking a remedial action; 

7 otherwise, not taking the remedial action. 

1 10. (Previously presented) The method of claim 9, wherein taking the 

2 remedial action involves: 

3 following the next pointer of the target node in an attempt to find an 

4 updated version of the target node; 

5 if an updated version of the target node is found, repeating the process of 

6 reading a snapshot of the multiple fields from the updated version of the target 

7 node; and 

8 if an updated version of the existing node is not found, indicating that the 

9 remedial action fails. 

1 11. (Original) The method of claim 1 , wherein atomically modifying 

2 the next pointer of the existing node to indicate that the existing node is deleted 

3 involves setting a "deleted bit" in the next pointer. 

1 12. (Previously presented) The method of claim 1 , wherein while 

2 atomically modifying the next pointer of the existing node, 

3 if the next pointer indicates that the existing node is already deleted, the 

4 atomic modification operation fails and the method further comprises taking a 

5 remedial action to deal with the fact that the existing node is already deleted; 

6 otherwise, continuing performing the atomic modification operation. 
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1 13. (Original) The method of claim 1 , wherein a given node in the 

2 linked list includes: 

3 a key that contains an identifier for the given node; 

4 one or more fields containing data values or pointers to data values 

5 associated with the given node; and 

6 a next pointer that contains the address of a node that immediately follows 

7 the given node in the linked list, and that also contains a deleted indicator, which 

8 indicates whether the given node has been deleted. 

1 14. (Original) The method of claim 1, further comprising periodically 

2 performing a garbage-collection operation to reclaim deleted nodes that have 

3 become unreachable. 

1 15. (Currently amended) A computer-readable storage medium storing 

2 instructions that when executed by a computer cause the computer to perform a 

3 method for performing a lock-free update to one or more fields in an existing node 

4 in a linked list, the method comprising: 

5 receiving a reference to the existing node in the linked list, wherein the 

6 existing node contains the one or more fields to be updated; 

7 obtaining a new node to be added to the linked list, wherein other 

8 processes do not possess references to the new node and therefore cannot initially 

9 access the new node; 

10 copying a snapshot of the existing node to the new node, which includes 

1 1 copying a next pointer of the existing node to the new node so that the new node 

12 points to a node immediately following the existing node; 

13 updating one or more fields in the new node that correspond to the one or 

14 more fields in the existing node; 
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15 performing a single atomic operation that modifies a next pointer of the 

16 existing node to point to the new node and also marks the next pointer to indicate 

17 that the existing node is deleted, whereby the new node becomes part of the linked 

1 8 list and the existing node is deleted in a single atomic operation; and 

19 splicing the existing node out of the linked list by atomically modifying 

20 the next pointer of a node immediately preceding the existing node in the linked 

21 list to point to the new node, instead of pointing to the existing node-^ 

22 wherein copying the snapshot of the existing node to the new node further 

23 involves examining the next pointer of the existing node to determine if the 

24 existing node has been deleted. 

1 16. (Cancelled) 

1 17. (Previously presented) The computer-readable storage medium of 

2 claim 15, wherein if a process that deleted the existing node does not perform the 

3 splicing operation, another process, which subsequently detects that the existing 

4 node has been deleted, performs the splicing operation. 

1 18. (Previously presented) The computer-readable storage medium of 

2 claim 15, wherein copying the snapshot of the existing node to the new node 

3 involves: 

4 copying the contents of the existing node to the new node; 

5 examining the next pointer of the existing node to determine if the existing 

6 node has been deleted; and 

7 if so, taking a remedial action; 

8 otherwise, not taking the remedial action. 
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1 19. (Previously presented) The computer-readable storage medium of 

2 claim 18, wherein taking the remedial action involves: 

3 following the next pointer of the existing node in an attempt to find an 

4 updated version of the existing node; 

5 if an updated version of the existing node is found, copying a snapshot of 

6 the updated version of the existing node to the new node; and 

7 if an updated version of the existing node is not found, indicating that the 

8 remedial action fails. 

1 20. (Original) The computer-readable storage medium of claim 15, 

2 wherein the method further comprises deleting a target node from the linked list 

3 by: 

4 receiving a reference to the target node to be deleted from the linked list; 

5 atomically marking a next pointer in the target node to indicate that the 

6 target node is deleted; and 

7 atomically modifying the next pointer of a node immediately preceding the 

8 target node in the linked list to point to a node immediately following the target 

9 node in the linked list, instead of pointing to the target node, thereby splicing the 
10 target node out of the linked list. 

1 21 . (Original) The computer-readable storage medium of claim 20, 

2 wherein after the target node is spliced out of the linked list, the method further 

3 comprises modifying the next pointer of the target node so that the next pointer 

4 remains marked but points to a node immediately preceding the target node 

5 instead of the node immediately following node the target node in the linked list. 
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1 22. (Original) The computer-readable storage medium of claim 15, 

2 wherein the method further comprises inserting an additional node into the linked 

3 list by: 

4 identifying a node immediately preceding the additional node in the linked 

5 list; 

6 identifying a node immediately following the additional node in the linked 

7 list; and 

8 splicing the additional node into the linked list by, 

9 setting the next pointer for the additional node to point to 

10 the immediately following node, and 

1 1 atomically updating the next pointer of the immediately 

12 preceding node to point to the additional node. 

1 23. (Previously presented) The computer-readable storage medium of 

2 claim 15, wherein the method further comprises reading a snapshot of multiple 

3 fields from a target node in the linked list by: 

4 reading the multiple fields from the target node; 

5 examining the next pointer of the target node to determine if the target 

6 node has been deleted; and 

7 if so, taking a remedial action; 

8 otherwise, not taking the remedial action. 

1 24. (Previously presented) The computer-readable storage medium of 

2 claim 23, wherein taking the remedial action involves: 

3 following the next pointer of the target node in an attempt to find an 

4 updated version of the target node; 
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5 if an updated version of the target node is found, repeating the process of 

6 reading a snapshot of the multiple fields from the updated version of the target 

7 node; and 

8 if an updated version of the existing node is not found, indicating that the 

9 remedial action fails. 

1 25. (Original) The computer-readable storage medium of claim 15, 

2 wherein atomically modifying the next pointer of the existing node to indicate that 

3 the existing node is deleted involves setting a "deleted bit" in the next pointer. 

1 26. (Previously presented) The computer-readable storage medium of 

2 claim 1 5, wherein while atomically modifying the next pointer of the existing 

3 node, 

4 if the next pointer indicates that the existing node is already deleted, the 

5 atomic modification operation fails and the method further comprises taking a 

6 remedial action to deal with the fact that the existing node is already deleted; 

7 otherwise, continuing performing the atomic modification operation. 

1 27. (Original) The computer-readable storage medium of claim 15, 

2 wherein a given node in the linked list includes: 

3 a key that contains an identifier for the given node; 

4 one or more fields containing data values or pointers to data values 

5 associated with the given node; and 

6 a next pointer that contains the address of a node that immediately follows 

7 the given node in the linked list, and that also contains a deleted indicator, which 

8 indicates whether the given node has been deleted. 
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1 28. (Original) The computer-readable storage medium of claim 15, 

2 wherein the method further comprises periodically performing a garbage- 

3 collection operation to reclaim deleted nodes that have become unreachable. 

1 29. (Currently amended) An apparatus that performs a lock- free update 

2 to one or more fields in an existing node in a linked list, comprising: 

3 a node obtaining mechanism configured to obtain a new node to be added 

4 to the linked list, wherein other processes do not possess references to the new 

5 node and therefore cannot initially access the new node; 

6 a copying mechanism configured to copy a snapshot of the existing node 

7 to the new node, which includes copying a next pointer of the existing node to the 

8 new node so that the new node points to a node immediately following the 

9 existing node; 

10 an updating mechanism configured to update one or more fields in the new 

1 1 node that correspond to the one or more fields in the existing node; 

12 a modification mechanism configured to perform a single atomic operation 

13 that modifies a next pointer of the existing node to point to the new node and also 

14 marks the next pointer to indicate that the existing node is deleted, whereby the 

15 new node becomes part of the linked list and the existing node is deleted in a 

16 single atomic operation; and 

17 a splicing mechanism configured to splice the existing node out of the 

1 8 linked list by atomically modifying the next pointer of a node immediately 

19 preceding the existing node in the linked list to point to the new node, instead of 

20 pointing to the existing node^ 

21 wherein copying the snapshot of the existing node to the new node further 

22 involves examining the next pointer of the existing node to determine if the 

23 existing node has been deleted. 
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1 30. (Cancelled) 



1 31. (Previously presented) The apparatus of claim 29, wherein if a 

2 process that deleted the existing node does not activate the splicing mechanism, 

3 another process, which subsequently detects that the existing node has been 

4 deleted, activates the splicing mechanism. 

1 32. (Previously presented) The apparatus of claim 29, wherein the 

2 copying mechanism is configured to: 

3 copy the contents of the existing node to the new node; 

4 examine the next pointer of the existing node to determine if the existing 

5 node has been deleted; and 

6 if so, to take a remedial action; 

7 otherwise, not taking the remedial action. 

1 33. (Previously presented) The apparatus of claim 32, wherein while 

2 taking the remedial action, the copying mechanism is configured to: 

3 follow the next pointer of the existing node in an attempt to find an 

4 updated version of the existing node; 

5 if an updated version of the existing node is found, to copy a snapshot of 

6 the updated version of the existing node to the new node; and 

7 if an updated version of the existing node is not found, indicating that the 

8 remedial action fails. 

1 34. (Original) The apparatus of claim 29, further comprising a deletion 

2 mechanism configured to delete a target node from the linked list, wherein the 

3 deletion mechanism is configured to: 

4 receive a reference to the target node to be deleted from the linked list; 

12 
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5 atomically mark a next pointer in the target node to indicate that the target 

6 node is deleted; and to 

7 atomically modify the next pointer of a node immediately preceding the 

8 target node in the linked list to point to a node immediately following the target 

9 node in the linked list, instead of pointing to the target node, thereby splicing the 
1 0 target node out of the linked list. 

1 35. (Original) The apparatus of claim 34, wherein after the target node 



2 is spliced out of the linked list, the deletion mechanism is configured to modify 

3 the next pointer of the target node so that the next pointer remains marked but 

4 points to a node immediately preceding the target node instead of the node 

5 immediately following node the target node in the linked list. 



1 36. (Original) The apparatus of claim 29, further comprising an 

2 insertion mechanism configured to insert an additional node into the linked list, 

3 wherein the insertion mechanism is configured to: 

4 identify a node immediately preceding the additional node in the linked 

5 list; 

6 identify a node immediately following the additional node in the linked 

7 list; and to 

8 splice the additional node into the linked list by, 

9 setting the next pointer for the additional node to point to 

10 the immediately following node, and 

1 1 atomically updating the next pointer of the immediately 

12 preceding node to point to the additional node. 

1 37. (Previously presented) The apparatus of claim 29, further 

2 comprising a reading mechanism configured to read a snapshot of multiple fields 
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3 from a target node in the linked list, wherein the reading mechanism is configured 

4 to: 

5 read the multiple fields from the target node; 

6 examine the next pointer of the target node to determine if the target node 

7 has been deleted; and 

8 if so, to take a remedial action; 

9 otherwise, not taking the remedial action. 

1 38. (Previously presented) The apparatus of claim 37, wherein while 

2 taking the remedial action, the reading mechanism is configured to: 

3 follow the next pointer of the target node in an attempt to find an updated 

4 version of the target node; 

5 if an updated version of the target node is found, to repeat the process of 

6 reading a snapshot of the multiple fields from the updated version of the target 

7 node; and 

8 if an updated version of the existing node is not found, indicating that the 

9 remedial action fails. 

1 39. (Original) The apparatus of claim 29, wherein while atomically 

2 modifying the next pointer of the existing node to indicate that the existing node 

3 is deleted, the modification mechanism is configured to set a "deleted bit" in the 

4 next pointer. 

1 40. (Previously presented) The apparatus of claim 29, wherein while 

2 atomically modifying the next pointer of the existing node, 

3 if the next pointer indicates that the existing node is already deleted, the 

4 modification mechanism is configured to: 

5 fail the modification operation fails; and to 
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take a remedial action to deal with the fact that the existing node is 
already deleted; 

otherwise, continue performing the atomic modification operation. 



1 41 . (Original) The apparatus of claim 29, wherein a given node in the 

2 linked list includes: 

3 a key that contains an identifier for the given node; 

4 one or more fields containing data values or pointers to data values 

5 associated with the given node; and 

6 a next pointer that contains the address of a node that immediately follows 

7 the given node in the linked list, and that also contains a deleted indicator, which 

8 indicates whether the given node has been deleted. 



1 42. (Original) The apparatus of claim 29, further comprising a garbage 

2 collection mechanism configured to periodically perform a garbage-collection 

3 operation to reclaim deleted nodes that have become unreachable. 
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